Amendments to the Claims 

1 . (Currently Amended) A method for dynamically managing a reassembly buffer, 
comprising: 

providing a plurality of data blocks and an indirect list; 

pointing, via entries in the indirect list, to allocated data blocks in the plurality of 
data blocks that currently store incoming data; 

if a free data block in the plurality of data blocks is required for the storage of 
incoming data, allocating the free data block for storing incoming data; aftdr 

if an allocated data block in the plurality of data blocks is no longer needed for 
storing incoming data, deallocating the allocated data block such that the deallocated 
data block becomes a free data block ; and 

selectively operating the reassembly buffer in a static mode by not deallocating 
allocated data blocks . 

2. (Original) The method of claim 1 , wherein the incoming data comprises TCP data. 

3. (Original) The method of claim 1 , further comprising a plurality of the indirect lists 
chained together. 

4. (Original) The method of claim 3, wherein an entry in one of the plurality of indirect 
lists contains a pointer to another of the plurality of indirect lists. 

5. (Original) The method of claim 1 , wherein the plurality of data blocks comprises a 
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pool of free data blocks, the method further comprising: 

allocating and deallocating free data blocks from the pool of free data blocks 
using a free list, wherein the free list includes entries each containing a pointer to a free 
data block. 

6. (Original) The method of claim 5, wherein the free list comprises a plurality of indirect 
lists chained together to form a stack. 

7. (Original) The method of claim 5, further comprising: 

providing a cache of free data blocks that are allocated before the free data 
blocks in the free list. 

8. (Original) The method of claim 6, wherein the free list comprises a head pointer for 
pointing to an entry, in one of the plurality of indirect lists forming the free list, containing 
a pointer to a next available free data block to be allocated. 

9. (Original) The method of claim 8, wherein: 

if the head pointer points to an entry that is not a last entry in one of the plurality 
of indirect lists forming the free list, that entry contains a pointer to the next available 
free data block to be allocated; and 

upon allocation of the next available free data block, the head pointer is moved to 
point to the next entry in the same indirect list. 
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10. (Original) The method of claim 8, wherein: 

if the head pointer points to a last entry in one of the plurality of indirect lists 
forming the free list, that last entry contains a pointer to a first entry in a next indirect list 
in the chain of indirect lists forming the free list; and 

the indirect list containing the last entry becomes a next available free data block 
to be allocated, and the head pointer is moved to point to the first entry in the next 
indirect list in the chain of indirect lists forming the free list. 

1 1 . (Original) The method of claim 6, wherein the free list comprises a tail pointer for 
pointing to an entry, in one of the plurality of indirect lists forming the free list, that will be 
assigned a pointer to a next allocated data block to be deallocated. 

12. (Original) The method of claim 1 1 , wherein: 

if the tail pointer points to an entry that is not a last entry in one of the plurality of 
indirect lists forming the free list, updating the pointer of that entry to point to the next 
allocated data block to be deallocated; and 

moving the tail pointer to point to a next entry in the same indirect list. 

1 3. (Original) The method of claim 1 1 , wherein: 

if the tail pointer points to a last entry in one of the plurality of indirect lists 
forming the free list, that last entry is updated to contain a pointer to a first entry in the 
next allocated data block to be deallocated, which becomes a next indirect list in the in 
the chain of indirect lists forming the free list; and 
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the tail pointer is moved to point to the first entry in the next indirect list in the 
chain of indirect lists forming the free list. 

Claims 14-21 (Cancelled). 

22. (Currently Amended) A method for storing out-of-order data segments in a 
reassembly buffer, comprising: 

providing a plurality of data blocks and an indirect list having a plurality of entries; 

providing each data segment with a sequence number, wherein the sequence 
number specifies which entry in the indirect list is to be associated with the data 
segment; 

determining if any of the plurality of data blocks has already been allocated to the 
specified entry in the indirect list; 

if a data block has already been allocated to the specified entry, storing the data 
segment in the allocated data block; and 

if a data block has not already been allocated to the specified entry, allocating a 
free data block for the storage of the data segment, and storing the data segment in the 
allocated free data block ; and 

selectively operating the reassembly buffer in a static mode by not deallocating 
allocated data blocks . 

23. (Original) The method of claim 22, wherein the step of determining if any of the 
plurality of data blocks has been allocated to the specified entry in the indirect list 
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comprises: 

providing each entry in the indirect list with a bit that indicates the allocated/free 
status of the entry; and 

examining the bit to determine if any of the plurality of data blocks has been 
allocated to the specified entry in the indirect list. 

24. (Original) The method of claim 22, wherein the sequence number specifies an offset 
in the allocated data block for the storage of the data segment. 

25. (Original) The method of claim 22, further comprising a plurality of indirect lists, 
wherein the sequence number specifies which of the plurality of indirect lists and which 
entry in the specified indirect list is to be associated with the data segment. 
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